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(54) Noise filter for Bayer pattern image data 

(57) A method of tittering and an image filter (1 0) is 
disclosed. The filter is provided for a digital camera in- 
cluding image sensors sensitive to light, a color filter 
placed over sensitive elements of the sensors and pat- 
terned according to a Bayer mosaic pattern layout and 
an interpolation algorithm joining together the digital in- 



formation provided by differently colored adjacent pixels 
in said Bayer pattern. The filter (10) is adaptive and in- 
cludes a noise level computation block (26) for operating 
directly on a said Bayer pattern data set of for each color 
channel thus removing noise while simultaneously pre- 
serving picture detail. 
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Description 

Field of Application 

5 [0001] This invention relates to a noise filter, and, more particularly to a noise filter for Bayer pattern image data. 
[0002] The invention also relates to a method of filtering noise in a Bayem pattern image data. 

Prior Art 

io [0003] Digital cameras generate a datafile that represents an image acquired by the camera. Generally, the camera 
acquires the information from the light/color sensors in the camera in a CFA (camera filter array) format A popular 
format for the CFA is a Bayer mosaic pattern layout, shown in Figure 1 . In a Bayer pattern, each pixel contains infor- 
mation that are relative to only one color component, for instance, Red, Green or Blue. Typically, the Bayer pattern 
includes a green information in every other space, and, in each row, either a blue or a red pixel occupies the remaining 

15 space. For instance, as seen in Figure 1 , row one alternates between green and red pixels, and row two alternates 
between green and blue. The end result is a mosaic made of red, green and blue points, where there are twice as 
many green points as red or blue. This can accurately represent an image because the human eye is more sensitive 
to the green data than either the red or blue. 

[0004] A typical camera includes a charge coupled device (CCDs) or CMOS image sensor that is sensitive to light. 
20 These image sensors are sensitive only to the intensity of light falling on it and not to the light's frequency. Thus, an 
image sensor of this kind has no capability to differentiate the color of light falling on. it. 

[0005] To obtain a color image from a typical camera sensor, a color filter is placed over the sensitive elements of 
the sensor. The filter can be patterned to be like the Bayer pattern discussed above. Then, the individual sensors are 
only receptive to a particular color of light, red, blue or green. The final color picture is obtained by using a color 

25 interpolation algorithm that joins together the information provided by the differently colored adjacent pixels. 

[0006] The images produced by digital still cameras, especially ones produced by CMOS technology, suffer from 
noise that is inherently present in the sensor when the image is captured. Thus, some modification of the datafile 
produced by the image sensor is needed. Oftentimes this modification comes as a filter or algorithm run on the image 
sensor data (the Bayer Pattern) to create a more realistic image. Processes are performed on it in an imaging process 

30 chain, e.g. white balance, gamma correction, etc, as shown in Figure 2. Finally, the corrected image is compressed 
and stored in memory as a color image. 

[0007] One problem with current image processing in current digital camera systems is that noise artifacts are difficult 
to differentiate from detail in the image itself. If noise artifacts are thought to be detail and left unfiltered, or details are 
thought to be artifacts and are filtered, image degradation occurs. 
35 [0008] Another problem exists in that current filtering methods operate on the image data as a whole and do not 
differentiate between the individual color channels making up the image. 

[0009] The technical problem solved by this invention is one of how to best filter a complex image file for noise, while 
at the same time preserving detail in the image. 

40 Summary of the Invention 

[001 0] The solution to the above-stated problem is that of using an adaptive filtering system in a Bayer pattern image 
independently for each of the color channels. The adaptive filter allows for a differing amount of filtering action performed 
based on the particular area of image and color of the current pixel. For example, the filtering action could be milder 
45 in textured areas of a color channel, where the inconsistencies in data could be related to detail in the scene, but 
stronger in uniform areas of the color channel where the aberration is more likely to be noise. 
[0011] Based on this principle, the technical problem is solved by an image filter as defined in Claim 1 , and further 
by a method of filtering noise as defined in Claim 8. 

[0012] The features and advantages of the method and device according to the invention will be apparent from the 
50 following description of an embodiment thereof, given by way of non-limitative example with reference to the accom- 
panying drawings. 

Brief description of the drawings 

55 [0013] 

Figure 1 is a diagram of a Bayer pattern mosaic layout used in digital cameras of the prior art. 
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Figure 2 is an example functional block diagram of image processes of a prior art digital camera. 

Figures 3A, 3B and 3C are diagrams of fitter masks for various colors in the Bayer pattern data, according to an 
embodiment of the invention. 

5 

Figure 4 is a flow diagram illustrating example processes that are present in embodiments of the inventive adaptive 
noise filter. 

Figure 5 is an example block diagram showing interrelationships of processes in the adaptive noise filter according 
10 to an embodiment of the invention. 

Figure 6A shows an example working window of a set of green pixels currently being filtered. 

Figure 6B shows an example working window of a set of non-green pixels currently being filtered. 

15 

Figure 7 is a chart of a human vision threshold factor for nearby pixels as it relates to the brightness of the desired 
pixel. 

Figure 8A is a graph of the K„ parameter as a function of the maximum distance value Dmax when the current 
20 pixel is green. 

Figure 8B is a graph of the parameter as a function of the maximum distance value Dmax when the current 
pixel is not green. 

25 Figure 9 is a graph showing a different way to generate the K n parameter using a gain variable. 

Figure 1 0 is an example diagram of a fuzzy function able to fuzzify relations of pixels according to an embodiment 
of the invention. 

30 Figure 11 is a diagram showing an edge of a Bayer pattern dataset. 

Figure 12 is a diagram of an image formed by pixels, highlighting the border made of two pixels. 
Figure 13A is an original control image. 

35 

Figure 13B is the image of Figure 13A after it has been modified by an adaptive noise filter according to an em- 
bodiment of the invention. 

Figure 14 is a diagram showing the strength levels of filtering as used in the conversion of Figure 1 3A to Figure 1 3B. 

40 

Figure 15 is an example test image having an increasing amount of noise from top to bottom. 
Figure 16 is a graph of noise power computed for different noise levels with reference to Figure 15. 
45 Detailed Description 

[0014] Embodiments of the invention operate directly on a noisy Bayer pattern data set to adaptively remove noise 
while simultaneously preserving picture detail. Once filtered, the Bayer pattern data is sent to the other standard image 
processing chain processes to produce the image stored on a memory medium. 
so [0015] Some of the calculation steps are similar to those found in US patent 6,108,455, which is assigned to the 
applicant, and incorporated herein in its entirety by reference. 

[0016] In one process, an algorithm filters the image acquired by the sensor of a digital still camera. Thus, the input 
image is in the Bayer pattern format. This noise filter computes a replacement value for the pixel under processing in 
the processing window based on a weighted average of the absolute values of degrees of similarity between the target 
55 pixel and the plurality of neighboring pixels. The noise filter recursively processes the noise levels to adapt its strength 
depending on the local features of the acquired image, as well as to adapt to changing noise levels of neighboring pixels. 
[001 7] Two different filter masks are used to filter the three color channels of Bayer pattern data, red, green and blue. 
One mask operates on the green channel exclusively. The other mask operates on both the red and blue channels, 
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but not simultaneously. 

[0018] Three different noise level estimations are computed; one for each color channel of the image, red, green 
and blue. The filter can be instructed to change its strength separately for each of the red, green and blue channels. 
Generally, the red and blue pixels making up the red and blue channels can be filtered at a higher strength than the 
5 green pixels, due to the way the human eye perceives color, but the process is capable of adjusting to any strength in 
any color channel. 

[0019] As stated above, two filter masks are used, depending if the green channel, or either the red or blue channels 
are being filtered. The different filter masks are illustrated in Figures 3A, 3B and 3C. Figure 3A shows a filter mask for 
the green pixels in the Bayer pattern, according to an embodiment of the invention. Generally, for a particular green 

10 pixel being tittered, the signal levels of the pixel being filtered and its neighboring pixels are examined. For instance, 
with reference to Figure 3A, a green pixel GO is the target pixel; a working window including a portion of the pixels 
neighboring the target pixel GO is established, for instance by including the neighboring pixels G1 , G2, G3, G4, G5, 
G6, G7, and G8. Similarly, with reference to Figure 3B, a working window is established with a filter mask for the Red 
channel. This filter mask differs from the filter mask shown in Figure 3A because, as discussed with reference to Figure 

is 1 , the pixel arrangement in the Bayer pattern is different for the green channel than either the red or blue channels. In 
the red filter mask, shown in Figure 3B, a target pixel R0 is surrounded by its neighboring pixels R1 , R2, R3, R4, R5, 
R6, R7, and R8. Similarly, the blue filter mask, shown in Figure 3C, has a target pixel B0 surrounded by its neighboring 
pixels B1 , B2, B3, B4, 35, B6, B7, and B8. In each of the cases for red, green and blue, there is one target pixel and 
eight neighboring pixels, which will be referred to generically as TO and T1-T8, respectively. 

20 [0020] The input image in the Bayer pattern format is scanned sequentially row by row, beginning on the top row, 
from left to right. In embodiments of the invention, the processing windows for the red and blue channels are identical, 
while the processing window for the green channel is different. When the picture is processed, only one of the two 
types of processing windows is selected, and thus, the selection is based dependent on whether the current pixel color 
is green. 

25 [0021] Figure 4 is a flow diagram illustrating example processes that are present in embodiments of the inventive 
adaptive noise filter. The adaptive noise filter 1 0 begins with a step of copying image borders 1 2, which will be discussed 
below. As described above, a determiner 16 then examines the current pixel TO to see if it is green or not. If TO is a 
green pixel, a green working window 18, such as seen in Figure 3A is produced. Instead, if TO is not green, a red/blue 
working window 20 is produced such as seen in Figures 3B or 3C. 

30 [0022] Once the mask and filter window is selected, a distance calculation is made in a difference calculator 22. In 
the difference calculator 22, an absolute value difference Di is determined between the target pixel TO and its neigh- 
boring pixels. Each difference Di represents the difference in between the value of the target pixel TO and the values 
of its neighboring pixels. The difference calculator 22 computes the absolute values of the differences Di between the 
target pixel TO value of the current working window and the values of its neighboring pixels T1 -T8 to produce the 

35 difference values D1 , D2, D3, D4, D5, D6 t D7, and D8. 

[0023] Once the differences in pixel values are calculated, the results are sent to a maximum and minimum block 
24. In that block, the maximum and minimum distance values are computed from the list of difference values D1-D8. 
The output of the max/min block 24 is the maximum difference Dmax and the minimum difference Dmin between the 
target pixel TO and its neighboring pixels T1-T8 of the current working window 1 8 or 20. 

40 [0024] These minimum and maximum differences are passed to a noise level computation block 26, which, without 
using autoexposured data, makes an estimation of a noise level NL associated with the processing window 1 8 or 20. 
Depending on whether the processing window 1 8 (green) or processing window 20 (red or blue) is the current window, 
different NL calculations are made and stored simultaneously, one for each color channel. Depending on the color of 
the current pixel TO, the noise level block 26 updates the relative noise level estimation for that particular color. Thus 

45 the noise level block 26 estimates the noise level according to the following calculations: 

NL R (t-1 ) = K n (t-1) * D^M) + [1 - K n (M )] * NL R (t-2) (1) 
NL G (t-1) = K n (t-1) * D^t-1) + [1 - K n (t-1)] * NL G (t-2) (2) 



NL B (t-1) = K n (t-1) * D^t-1) + [1 K n (t-1)] * NL B (t-2) (3) 

55 

[0025] where NL X is the noise level of the particular noise channel, x; is a parameter that determines the strength 
of filtering to be performed by the adaptive noise filter 1 0, as discussed in the above-referenced US patent and as 
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further discussed below, and wherein D max is the maximum distance value computed for the particular color channel 
in max/min block 24. 

[0026] Examples of the interrelationship of different processes can be seen in the example block diagram of the 
inventive adaptive noise filter 10 in Figure 5. In that figure the difference calculator 22 takes its input from the current 
5 processing window 1 8 or 20. The output from the difference calculator 22 is passed to the max/min block 24, which 
passes Dmax and Dmin values for each color to the noise level block 26. The K n parameter is also an input to the 
noise level block 26. 

[0027] Generally, these processes used in the adaptive noise filter 1 0 can be implemented in software or hardware, 
although hardware is generally preferred for performance reasons. It is fundamental to process the input noisy image 

io as quickly as possible using a minimum amount of resources to perform all of the computations. In order to achieve 
these goals, the noise level computation block 26, according to an embodiment of the invention, uses a recursive 
implementation. Typically, two image buffers can be used to execute the entire filtering process. One buffer (an input 
buffer) contains the image to be filtered; the other buffer (the output buffer) contains the filtered image. 
[0028] In order to make best use of the resources required by the processes, the filtered value of the current target 

15 pixel TO is computed using the pixel values that have already been filtered. For example, if TO is the target pixel, and 
T1 , T2, T3 and T4 have already been processed, then T5, T6, T7 and T8 have yet to be processed. Keeping track of 
already filtered pixels is a good practice to reduce the computational requirements of the various processes. As the 
Bayer pattern image is scanned row by row, the already filtered values are available in memory and they can be used 
to filter the next pixel without having to reload into the memory the old unfiltered values of T1 , T2, T3 and T4. This 

20 process can be used for both the Green working window 1 8, and the Red/Blue working window 20. 

[0029] Figure 6A shows an example working window 1 8 of a set of Green pixels, GO (the target pixel), G1 , G2, G3 
and G4, which have already been filtered, and G5, G6, G7 and G8 which have yet to be filtered. 
Figure 6B shows an example working window 20, which in this case happens to be blue, although it would be identical 
for the red color channel. In Figure 6B, B0 is the target pixel being filtered, B1 , B2 t B3 and B4 have already been 

25 filtered, and B5, B6, B7, and B8 have not been filtered yet. 

[0030] Returning back to Figure 5, an human visual system (HVS) evaluator 30 is shown, which receives its input 
from the working windows 1 8 and 20. The HVS evaluator 30 factors the human eye's response to a brightness change 
according to the function shown in Figure 7. In that figure, the X-axis measures possible brightness values on a scale 
between 0 and 1 023, while the Y axis charts the threshold level where the human eye can determine a difference in 

30 grey level values between a current pixel and its neighboring pixels. As shown in Figure 7, when a pixel is in the middle 
(x=51 2) of the dark (x=0) and the brightest value (x=1 023), the HVS threshold of the human eye is the lowest. Therefore, 
the HVS threshold of the human eye is the highest when the pixels are very bright or very dark, as shown in Figure 7. 
[0031 ] The factor from the HVS evaluator 30 is summed with the output of the noise level block 26 and provide to a 
local feature inspector block 32 (Figure 5). That block 32 computes the K,, parameter that is used to modulate the 

35 strength of the filtering process to be executed on the current pixel TO in the noise level block 26. Depending on the 
color of the current pixel TO, either green or red/blue, two different local feature inspector functions are used. Specifically, 
if the current pixel being filtered is green, then the standard local feature inspector block is used. This is illustrated in 
Figure 8A, which is a graph of the K,, parameter as a function of the maximum distance value Dmax when the current 
pixel is green. Shown in Figure 8A is a value Th 3 , which is the noise value plus the HVS value for the current pixel TO, 

40 (Th 3 = NL + HVS). In Figure 8A, the K n parameter is a straight line starting at 1 (when Dmax is at its minimum), and 
extending down to Th 3 . Figure 8B, conversely, is a graph of the Kp parameter as a function of the maximum distance 
value Dmax when the current pixel is not green. Figure 8B introduces another value to the calculation of the pa- 
rameter, which is the noise level NL. Thus, when Dmax has a value that is less than or equal to the NL, then the Kn 
parameter will be 1 , otherwise the K n parameter has a value found along the line between 1 and Th 3 . This augments 

45 the filter strength on the red and blue channels compared to the green channel, because the !<„ parameter for the 
green channel can only be 1 when Dmax is at 0, while the K n parameter for the red and blue channels is always 1 
when Dmax is less than or equal to the NL. 

[0032] An additional way to control the degree of filtering the Bayer pattern data is to include a gain factor used by 
the autoexposure control (AEC). Such block including AEC is illustrated as 34 in Figure 5. The degree of filtering can 

50 be modulated depending on the current gain factor used by the AEC block 34. The autoexposure process in a digital 
camera generates an appropriate set of exposure settings and gain settings in order to obtain a correctly exposed 
scene. If the image scene is correctly exposed, then no gain factor needs to be applied to the image. If, on the other 
hand, the image cannot be correctly exposed, then the autoexeposure process of the camera computes a gain factor, 
which is a sort of coefficient that is applied to the image. The higher the gain, the brighter the image. There are some 

5 5 drawbacks to this universal system, however. If the gain is set to a too high value, noise is also enhanced in the image. 
Therefore, when the gain is high, the noise filter must act with a higher strength, and when the gain is low, or at zero, 
then the noise filter should act with a lower strength. 

[0033] The adaptive noise filter 1 0 can include a process that uses the following approach, as illustrated with refer- 
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ence to Figure 9. That figure shows how an extra factor (the AEC gain factor) can be used to create the K,, parameter. 
If G is the current AEC gain factor computed by the AEC block 34 of Figure 5, and Gmax is the Maximum value of the 
gain factor, which will depend from the image sensor), then a ratio of G/Gmax can be calculated. This ratio, as shown 
in Figure 9, is multiplied by the noise level factor NL to determine the highest Dmax value that will have the K n parameter 

5 equal to 1 . This differs to the graph shown in Figure 8B, which did not include the gain G/Gmax ratio factor. Thus, if to 
obtain the best exposed image G is set to Gmax, then this means that the G/Gmax ratio is 1 1 so the threshold that 
separates the maximum degree of filtering (K,, = 1 ) from the other degrees of filtering is the noise level NL. Conversely, 
if the correctly exopsed picture is reached with a gain G such that 0<= G <= Gmax, then NL*G/Gmax <= NL, because 
G/Gmax <=1 , So, the treshold that is used to discriminate between the higher degree of filtering from the other degrees 

10 js lower, hence the filter strength is lowered. This technique can be applied to all of the three color channels, or it may 
be used on only the red/blue channels, while the green channel may be filtered in the standard mode shown in Figure 8A. 
[0034] With reference to Figure 5, it may be necessary for the AEC block 34 to provide its output prior to the time 
the noise levels are calculated by the noise level computation block 26. This is not problematic because the noise level 
computation block 26 and other portions of the adaptive noise filter 10 are not restricted to be the first element of an 

15 image processing chain. The adaptive noise filter 1 0 can actually be positioned much later in the image manipulation 
process (Figure 2), such as within the defect correction block, if necessary. When the adaptive noise filter 10 is posi- 
tioned in the defect correction block of the image processing chain, it accepts as an input the noisy pixel. Then, the 
de-noised value is passed as output from the adaptive noise filter to the defect correction algorithms in order to generate 
the final denoised and defect corrected pixel of the Bayer pattern to be passed to the rest of the image processing chain. 

20 [0035] The final process to be performed on the pixel value is based on fuzzy logic. The membership computation 
block is associated to a fuzzy function bounded by two threshold values Th1 and Th2. The fuzzy function fuzzifies the 
relation "the target pixel TO and its neighbor pixel Ti are similar", where Ti is any of the neighboring pixels T1 - T8. For 
each neighboring pixel Ti of TO, a coefficient Ki is computed, which weights the similarity between T and Ti. These 
weight coefficients Ki are later used in the final determination of the filtered value. Thus, for every pixel TO, there will 

25 be eight coefficient values, K1 -K8, where K1 weighs the similarity between TO and T1 , K2 weighs the similarity between 
TO and T2, etc., up to K8. 

[0036] An example diagram of a fuzzy function able to fuzzify the above relation is shown in Figure 10. The two 
threshold values Th1 and Th2 can be factored according to the following equations: 

30 

™1 = K n (t) * D^ (t) + [1- K n (t)] * D mjn (t) (4) 



Th2 = K n (t) * D max (t) + [1- K n (t)] * D mjn (t) * ([D^t) + D min (t)] 12) (5) 

35 

[0037] The value of Ki can be expressed through the following relations: 

Ki = 1,whenDi<=Th1 (6) 

40 

Ki = (Th2-D0/(Th2-7h1),whenTh1 <Di<Th2 (7) 



45 Ki = 0, when Th2 <= Di (8) 

[0038] These values are calculated in a threshold calculation block 36 shown in Figure 5, which accepts as inputs 
the threshold factor Kn, Dmin, and Dmax, and produces the threshold values Th1 and Th2 shown above. 
[0039] These threshold values are input to a coefficient calculator 38, which calculates the Ki values of equations 6, 
50 7 and 8. 

[0040] A final output of the adaptive noise filter 10 is the filtered value of the current target pixel TO. By repeating 
this process sequentially for every pixel produced by the camera sensor, the final filtered image is obtained at its output. 
The output of the noise filter 1 0 can be shown to be as follows: 

55 



6 



EP 1 289 309 A1 



PixOut - 1£ K,{t). 7) + [1 -*,(/)]■ T 0 



(9) 



5 



[0041 ] As stated previously, the adaptive noise fitter 1 0 works on Bayer pattern source data. Considering the shape 
of the processing windows it can be noticed that it is not possible to process those pixels belonging to the first and last 
two rows of the image, and those pixels belonging to the first and last two columns, because there are not enough 
pixels to create a full working window 18 or 20 (Figures 3A, 3B and 3C). This concept is illustrated with reference to 
10 Figure 1 1 , a Bayer pattern showing the first five columns and five rows of an edge of an image is shown. It is impossible 
to create a full working window 1 8 for the first green pixel located in the first column and first row, because it does not 
have enough surrounding pixels. 

[0042] Therefore, as illustrated in Figure 12, some embodiments of the invention leave the two-pixel-wide borders 
of the image in their original condition, and do not filter these particular borders. That is why, with reference to Figure 
is 4, the border copying step 12 is the first step to be performed. Thus, in order to obtain an image that has the same 
number of rows and columns as the orignaly input noisy image, the first and last two rows and columns are copied 
directly to the output buffer, although they may be temporarily stored prior to insertion into the output buffer. This step 
is shown as the block 40 of Figure 5, the filter output block. 

[0043] Figures 13A and 13B show an original image and an image taken from the output of an embodiment of the 
20 adaptive noise filter 10, respectively. The adaptiveness of the algorithm is clearly visible by viewing these figures. For 
instance, the walls and paper on the desk have a much reduced noise- value, but detail is not lost around the buttons 
of the phone, for instance. 

[0044] Figure 1 4 is a diagram generated showing the strength of the filtering of Figure 1 3A to produce Figure 1 3B. 
The light grey zones represent heavily filtered areas, and dark grey zones represent lightly filtered areas. The paper 

25 on the desk had one of the strongest amounts of noise filtering applied to it, while the borders of the objects get almost 
no filtering at all — to preserve their details. One of the reasons for this is seen with reference to equation 8 above. 
That equation forces Ki, which is directly involved in the output pixel equation of equation 9 to zero when the distance 
Di is greater than the second threshold, Th2. At the borders of objects, there will be a large distance in pixel values, 
because of the sharp edge. Using the adaptive filtering techniques described herein, the sharp edges (and hence 

30 detail) is preserved, while other noise, such as in large blocks of monochrome color (as in sheets of paper, walls, and 
other large surfaces) get a strong amount of noise filtering, thus producing an overall high quality image. 
[0045] In testing different embodiments of the processes, a synthetic image was used to determin how much noise 
the algorithm is capable of removing. Figure 15 is the test image, which has an increasing amount of noise from top 
to bottom. To modulate the power of the added noise, the variance value of a gaussian distribution was manipulated. 

35 The mean value of the noise statistical distribution is assumed to be zero. 
[0046] If: 

'noisy denotes a noisy Bayer pattern; 

40 'filtered denotes the Bayer pattern filtered by the adaptive noise filter 1 0; and 

'original denotes the original noiseless Bayer pattern, 

[0047] Then: 



50 [0048] Where Iadded_noise 13 the 'mage that contains only the noise that was artificially, added to (original- Whereas 
'residual_noise ,s tne 'mage containing the residual noise after filtering. Given an image x(n,m); N*M, noise power 
can be computed according to the following formula: 



45 



'noisy " 'original - 'addedjmoise; and 



'filtered " 'original 



= 'l 



'residual_noise- 



55 




(10) 
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[0049] Noise power has been computed for both 'adoed.noise and 'residualjmoise using the image of Figure 15, 
transformed into decibel (dB) form, and graphed in Figure 1 6. The y-axis of the graph in Figure 16 represents the noise 
power expressed in dBs, and the x-axis represents the variance of the noise distribution. The difference between the 
two plots indicates how much noise was reduced using the embodiment of the adaptive noise filter 1 0. In this test, the 
noise power of the tittered image is about 7 dB less than the original noise power, however, the adaptive noise filter is 
still able to discriminate between high texture and low texture areas. 

[0050] One of the attractive benefits of embodiments of the adaptive noise filter 1 0 is the ability to work directly on 
Bayer pattern data. It adaptations are color specific, and therefore produce better overall results than if they are simply 
averaged. Using gain factors from the autoexposure data combined with the human visual system, excellent pre- 
determinations are able to be made about how much filtering can be safely applied to specific pixels. Also, the noise 
filter works quickly because of its ability to recursively compute based on pixel values already calculated, using less 
amount of memory in a hardware implementation. 

[0051] Changes can be made to the invention in light of the above detailed description. In general, in the following 
claims, the terms used should not be construed to limit the invention to the specific embodiments disclosed in the 
specification and the claims, but should be construed to include all methods and devices that are in accordance with 
the claims. Accordingly, the invention is not limited by the disclosure, but instead its scope is to be determined by the 
following claims. 



1 . Improved image filter for a digital camera including image sensors sensitive to light, a color filter placed over 
sensitive elements of the sensors and patterned according to a Bayer mosaic pattern layout and an interpolation 
algorithm joining together the digital information provided by differently colored adjacent pixels in said Bayer pat- 
tern, characterized in that said filter (1 0) is adaptive and includes a noise level computation block (26) for operating 
directly on a said Bayer pattern data set of for each color channel thus removing noise while simultaneously pre- 
serving picture detail. 

2. Improved image filter according to claim 1 wherein at least two filter masks are used, one for the green channel 
and the other for the red and blue channels. 

3. Improved image filter according to claim 2 wherein the filter masks for the red and blue channels are identical while 
the filter mask for the green channel is different. 

4. Improved image filter according to claim 1 including: a determiner block (16) for examining a current pixel (TO) in 
a processing window and determining if it is a green pixel to select a corresponding filtering mask; a difference 
calculator (22) for determining an absolute value difference (Di) between said current pixel (TO) and the values of 
its neighboring pixels in said processing window; a maximum and minimum block (24) for computing the maximum 
and minimum distance values from a list of difference values (D1 D8); a noise level computation block (26) for 
estimating a noise level (NL) associated with said processing window. 

5. Improved image filter according to claim 4 further including a gain factor block (34) comprising an autoexposure 
control system for generating an appropriate set of exposure and gain settings fed to said noise level computation 



6. Improved image fitter according to claim 4 wherein said noise level computation block (26) uses a recursive im- 
plementation and extimates the noise level according to the following calculations: 



Claims 



block (26). 



NL R (t-1) = K n (M) * D^M) + [1 - K n (t-1)] * NL R (t-2) 



(D 



NL G (t-1) = K n (t-1) * D^t-1) + [1 - K n (t-1)] * NLq (t-2) 



(2) 



NL B (t-1) = K n (t-1) * D^t-1) + [1 - Kn (t-1 )] * NL B (t-2) 



(3) 
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where NL X is the noise level of the particular noise channel, x; K„ is a parameter that determines the strength 
of filtering to be performed by the adaptive noise filter (10), and D max is the maximum distance value computed 
for the particular color channel in max/min block (24). 

A digital camera, comprising: 

a sensor for sensing an image and producing a first signal; 

a Bayer pattern producer coupled to said sensor and structured to produce a Bayer pattern from said first signal; 

a splitter structured to split said Bayer pattern into separate color channels; 

characterized in that it further comprises an image filter according to claim 1 . 

Method for filtering noise in a digital camera including image sensors sensitive to light, a color filter placed over 
sensitive elements of the sensors and patterned according to a Bayer mosaic pattern layout and an interpolation 
algorithm joining together the digital information provided by differently colored adjacent pixels in said Bayer pat- 
tern, characterized by the following steps: 

scanning sequentially row by row the Bayer pattern format; 

providing a processing window for each color channel of said Bayer pattern data set; the processing windows 
for the red and blue channels being identical, while the processing window forthe green channel being different; 
each processing window having a target pixel and a plurality of neighboring pixels; 

selecting a filtering mask and a corresponding processing window in dependence on whether the current target 
pixel color is green; 

filtering the target pixel computing also the noise level (NL) of a color channel and providing a filtered pattern 
format depending on said noise level. 

Method according to claim 8, characterized in that the filtered value of the current target pixel (TO) is computed 
using the pixel values that have already been filtered during said scanning step. 
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